草庐IT

java - JSF 中 GET 参数的 UTF-8 编码

全部标签

ruby - Ruby 的 Object#const_get 是如何工作的?

我最近发现Ruby(2.2.1)有一些“有趣”的行为。moduleFooclassFooendclassBarendendFoo.const_get('Foo')#=>Foo::FooFoo.const_get('Bar')#=>Foo::BarFoo.const_get('Foo::Foo')#=>FooFoo.const_get('Foo::Bar')#=>NameError:uninitializedconstantFoo::Foo::BarFoo.const_get('Foo::Foo::Bar')#=>Foo::BarFoo.const_get('Foo::Foo::Foo:

ruby - 使用默认 proc 编码 ruby​​ 哈希 - 删除默认 proc?

我有一个带有默认过程的哈希,我想将其编码到一个文件,但默认过程阻止我这样做。与其编写我自己的_dump和_load方法,不如删除默认过程?在我进行编码的时候,我再也不需要默认过程了。 最佳答案 只需重置默认值:h.default=nil更明确地说:defdumpable_hash(h)returnhunlessh.default_proccopy=h.clonecopy.default=nil#clearthedefault_proccopyend在Ruby2.0中,你can如果您愿意,也可以编写h.default_proc=nil

ruby-on-rails - 如何在 Rails 中的 CSV 解析期间更改编码

我想知道如何在导入和解析CSV文件时更改它的编码。我有这段代码:csv=CSV.parse(output,:headers=>true,:col_sep=>";")csv.eachdo|row|row=row.to_hash.with_indifferent_accessinsert_data_method(row)end当我读取我的文件时,我得到这个错误:Encoding::CompatibilityErrorinFileImportingController#load_fileincompatiblecharacterencodings:ASCII-8BITandUTF-8我阅读了

ruby-on-rails - 如何创建一个带有参数的 Rails 4 关注点

我有一个名为User的ActiveRecord类。我正在尝试创建一个名为Restrictable的关注点,它接受如下一些参数:classUser然后我想提供一个名为restricted_data的实例方法,它可以对这些参数执行一些操作并返回一些数据。示例:user=User.find(1)user.restricted_data#Returnsallcolumnsexcept:id,:name,:email我该怎么做? 最佳答案 如果我正确理解你的问题,这是关于如何写这样一个问题,而不是关于restricted_data的实际返回值

ruby - 使用适当的参数转义从 ruby​​ 在后台执行 shell 命令

我必须在后台运行一个命令,但我想对其参数进行适当的转义。system("rakesend_mailssubject='#{params[:subject]}'2>/dev/null1>/dev/null&");如果我写system("rake","send_mails",params[:subject])那么我没有重定向的“位置”和&符号。如果我不这样做,我就没有对subject参数进行转义。我该如何解决? 最佳答案 在Ruby1.9中,尝试Process.spawn:#Spawnanewprocessandruntherakeco

ruby-on-rails - 使用 Rails Assets 管道在 JavaScript 文件中编码问题

我正在使用Rails3.1和Assets管道(ruby1.9.2)。在尝试提供具有utf-8编码字符串的javascriptjs.erb文件时出现以下错误invalidbytesequenceinUS-ASCII我在我的environment.rb文件中设置了Encoding.default_external="UTF-8"。我如何让Assets管道以不同的编码提供服务?编辑仅当我在文件外部生成utf-8字符时才会出现该错误(在本例中是通过从数据库查询)。如果我添加,错误就会消失到文件的顶部。我猜这里会进行某种编码猜测,但如果没有那种骇人听闻的解决方案,我该如何避免呢?

ruby-on-rails - 设计:不允许的参数

我不知道为什么,但下面的代码就停止工作了(我什至没有注意到它是怎么发生的)routes.rbdevise_for:users,components:{registrations:'registrations',sessions:'sessions'}registations_controller.rbclassRegistrationsController正如我所说,之前一切正常,但现在我得到:ProcessingbyDevise::RegistrationsController#createasHTMLParameters:{"utf8"=>"✓","authenticity_tok

Ruby:按字节长度限制 UTF-8 字符串

ThisRabbitMQpage状态:Queuenamesmaybeupto255bytesofUTF-8characters.在ruby​​(1.9.3)中,如何按字节数截断UTF-8字符串而不在字符中间中断?生成的字符串应该是符合字节限制的最长可能的有效UTF-8字符串。 最佳答案 对于Rails>=3.0,你有ActiveSupport::Multibyte::Chars限制方法。来自API文档:-(Object)limit(limit)将字符串的字节大小限制为字节数而不破坏字符。当由于某种原因字符串的存储空间有限时可用。例子

ruby-on-rails - Rails 3,导入前检查 CSV 文件编码

在我的应用程序(Rails3.0.5、Ruby1.8.7)中,我创建了一个导入工具来从文件导入CSV数据。问题:我要求我的用户以UTF-8编码从Excel中导出CSV文件,但大多数时候他们并没有这么做。如何在导入前验证文件是否为UTF-8?否则导入将运行但会产生奇怪的结果。我使用FasterCSV导入。错误的CSV文件示例:;VallÈeduRhÙne;CÙteRotie;谢谢。 最佳答案 您可以使用CharlockHolmes,Ruby的字符编码检测库。https://github.com/brianmario/charlock_

ruby - String#encode 未修复 "invalid byte sequence in UTF-8"错误

我知道有很多关于此错误的类似问题,而且我已经尝试了很多,但都没有成功。我遇到的问题涉及字节\xA1并且正在抛出ArgumentError:invalidbytesequenceinUTF-8我尝试了以下但没有成功:"\xA1".encode('UTF-8',:undef=>:replace,:invalid=>:replace,:replace=>"").sub('','')"\xA1".encode('UTF-8',:undef=>:replace,:invalid=>:replace,:replace=>"").force_encoding('UTF-8').sub('','')"